package com.atguigu.servicebase.config;

import com.google.common.base.Predicates;
import org.springframework.context.annotation.Bean;
import org.springframework.context.annotation.Configuration;
import springfox.documentation.builders.ApiInfoBuilder;
import springfox.documentation.builders.PathSelectors;
import springfox.documentation.service.ApiInfo;
import springfox.documentation.service.Contact;
import springfox.documentation.spi.DocumentationType;
import springfox.documentation.spring.web.plugins.Docket;
import springfox.documentation.swagger2.annotations.EnableSwagger2;

/**
 * @Author 徐超
 * @Create 2024/10/14 23:43
 */
@Configuration//配置类
@EnableSwagger2//swagger注解
public class SwaggerConfig {
    //访问地址：http://localhost:8001/swagger-ui.html
    @Bean
    public Docket webApiConfig(){
        //配置swagger插件
        return new Docket(DocumentationType.SWAGGER_2)//类型
                .groupName("webApi")//分组名称
                .apiInfo(webApiInfo())
                .select()
                //表示如果说路径中包含/admin/这个路径，那这个接口是不会进行显示的
                //.paths(Predicates.not(PathSelectors.regex("/admin/.*")))
                .paths(Predicates.not(PathSelectors.regex("/error.*")))
                .build();
    }

    private ApiInfo webApiInfo(){
        return new ApiInfoBuilder()
                .title("网站-课程中心API文档")
                .description("本文档描述了课程中心微服务接口定义")
                .version("1.0")
                .contact(new Contact("java", "http://atguigu.com", "1123@qq.com"))
                .build();
    }
}
